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METHOD AND APPARATUS FOR CONFIGURING A COMPUTER 

BACKGROUND OF THE INVENTION 

5 1. FIELD OF THE INVENTION 

This invention relates to the field of computer software, and, more 
specifically, to network protocols and configuration. 

10 Portions of the disclosure of this patent document contain material 

that is subject to copyright protection. The copyright owner has no objection 
to the facsimile reproduction by anyone of the patent document or the patent 
disclosure as it appears in the Patent and Trademark Office file or records, but 
otherwise reserves all copyright rights whatsoever. Apple, Macintosh, 

15 AppleTalk, AppleScript, and all Apple-based trademarks and logos are 

trademarks or registered trademarks of Apple Computer, Inc. in the United 
States and other countries. 

2. BACKGROUND ART 

20 

In modern computing environments, it is commonplace to employ 
multiple computers or workstations linked together in a network to 
communicate between, and share data with, network users. A network also 
may include resources, such as printers, modems, file servers, etc., and may 
25 also include services, such as electronic mail. 

A network can be a small system that is physically connected by cables 
(a local area network or "LAN"), or several separate networks can be 
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connected together to form a larger network (a wide area network or 
"WAN"). Other types of networks include the internet, tel-com networks, 
the World Wide Web, intranets, extranets, wireless networks, and other 
networks over which electronic, digital, and /or analog data may be 
5 communicated. Individual computers often use various ports to physically 
connect to a network. For example, if you need to dial into a network using 
the phone lines and a modem, the modem port may be utilized. Other ports 
that may be used include a Printer Port, Ethernet, Infrared, and Remote 
Access. 

10 

To enable the computers on a network to communicate with each 
other, a set of standardized rules for exchanging the informahon between the 
computers, referred to as a "protocol", is utilized. Protocols generally specify 
the data format, timing, sequencing, and error checking of data transmissions. 
15 Numerous protocols are used in the. networking environment. For example, 
transmission control protocol /internet protocols ("TCP/IP") are the protocols 
used on the internet and on many multiplatform networks, and AppleTalk is 
the network protocol built into every Macintosh computer. 

20 To enable individual computers to utilize a specific protocol, 

numerous computer settings, including the settings for the desired protocol, 
must be properly configured. Several software applications for controlling 
the settings, referred to here as "utilities" may be utilized to control the 
configuration and modification of a protocol to enable network capabilities. 

25 For example, in a Macintosh environment, the following "control panel" 
user interface utilities may be utilized to configure a computer for various 
types of network access: AppleTalk, TCP/IP, OT/PPP (Open Transport /Point- 
to-Point), Infrared, Dial Assist, and Modem. Further, the information and 



wo 99/57957 PCT/US99/09797 

3 

data relating to each protocol are stored independently from other protocols 
in individual files. These files are accessible to one user at a time. If two 
users desire to access the configuration file, the first user to open the file with 
the information is permitted access and the second user is denied access. 
5 Some prior art methods permit multiple users to read a file at the same time. 
However, these methods do not provide any protection for those users 
should the file be modified by another user while they are reading it. 



In some situations, if one of the protocols is configured in a certain 

10 manner, one of the other protocols does not operate. For example, if two 
configurations or devices try and use the same non-sharable port, the user 
may not be allowed to use the desired port until the conflicting device is 
deactivated (e.g., a printer can't be activated if it shares the same port as 
"modem settings"). To deactivate the conflicting device, the user has to 

15 search numerous control panels to locate the conflicting device and 

deactivate or delete the conflicting configuration by adjusting the settings. 
Thus, the use of an individual control panel for each protocol forces the user 
to make adjustments and modifications in numerous control panels in order 
to properly configure the computer. For example, if a user desires to enable 

20 multiple networking protocols (e.g., one TCP/IP protocol with a static IP 
address (IP addresses are discussed below), one TCP/IP protocol with a 
dynamic IP address, and one AppleTalk protocol), numerous control panels 
for each protocol must be accessed and configured properly. In addition, if a 
user desires to connect to the internet, but has a protocol other than TCP/IP 

25 active (e.g., AppleTalk), the connection cannot be processed. The user may 
have to deactivate the active protocol (e.g., AppleTalk) using that protocol's 
control panel, and then activate the TCP/IP protocol using the TCP/IP control 
panel. 
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To route messages and communicate between computers using a 
TCP/IP protocol, each individual computer must be identified with a unique 
identifier or address. The unique identifier is referred to as an internet 

5 address or Internet Protocol (IP) address. An individual computer can be 

assigned a static IP address that does not change. An individual computer can 
also maintain a dynamic IP address such that whenever it connects to the 
network, the computer is assigned an IP address. In this manner, each time 
the individual computer connects to the network, a different IP address may 

10 be assigned to the computer. 

It is often beyond the scope of the user's knowledge to configure a 
networking protocol. For example, an employee that solely performs word 
processing is not Ukely to have the knowledge to configure his/her computer 
15 for network access and operation. Thus, it is desirable for a network 
administrator to be able to configure a user's computer from the 
administrator s or another's computer (referred to as "remote 
configuration"). 

20 To enable a computer to execute a sequence of instructions or 

commands, a computer program is utilized. One type of computer program 
that provides for the automation of a task or a series of tasks is called a script. 
A script can be used to perform simple tasks such as a file back-up , or more 
complex tasks such as adding capability to a program or presentation. A 

25 scripting language is used to create a script. 

Two common methods are utilized in scripting languages: (1) Event 
Scripting; and (2) Semantic Scripting. Event scripting consists of mimicking a 



wo 99/57957 



5 



PCT/US99/09797 



user's actions and events as they are performed in a user interface. For 
example, copying the user's actions entailed in moving a mouse over a 
screen location containing a checkbox for activating sound and depressing the 
mouse button. Semantic scripting consists of function specific commands 
5 that perform specific actions. For example, the execution of a command to 
activate sound. In the Macintosh environment, one type of semantic 
scripting language that is often utilized is called AppleScript. 

To enable network configuration, one prior art method referred to as 
10 "Location Manager") allows users to assign specific settings to a "location" for 
a variety of capabilities including networking, printers, time zone, file 
sharing, sound, and frequently used applications. Once a location is set up, a 
user can select that location and the computer system recognizes the user's 
preferences for that environment. For example, a home location and an 
15 office location may be set up for the various printers and networks available 
at the user's home and office. However, it is not possible for a network 
administrator to remotely configure a computer or adjust network settings. 

Another prior art method used to configure a network referred to as 
20 "Netlnfo" provides for a centralized database that contains the available 
configurations. When a user wants to configure his/her computer for 
network capabilities, the user accesses the centralized database to determine 
what options are available. However, it is not possible for a network 
administrator to remotely configure a user's computer or adjust network 
25 settings. This prior art method is more fully described in United States Patent 
No, 5,410,691 entitled "Method and Apparatus for Providing a Network 
Configuration Database" issued on April 25, 1995 and United States Patent 
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No. 5,459,863 entitled "Method of Maintaining Integrity in a Network 
Database" issued on October 17, 1995. 

Another prior art method provides the ability to swap various 
5 configuration files in order to configure a computer. However, the system is 
not notified when the file swapping occurs and does not recognize the new 
configuration. To enable the system to recognize the new configuration, the 
computer must be restarted or one of the control panels must be manually 
adjusted, 

10 



wo 99/57957 PCT/US99/09797 

7 

SUMMARY OF THE INVENTION 

The invention provides for the configuration of a computer. One 
embodiment of the invention combines the prior art control panels related to 
5 networking into a consolidated Network Setup Control Panel. In addition, 
the invention provides for computer configuration by scripting. The 
configuration may be for any type of system setting or for network 
configurations and protocols. Through scripting, a computer may be 
configured locally or remotely on a network. 

10 

One embodiment of the invention provides for a centralized database 
consisting of the collected data relating to available configuration settings. 
This database is not limited to configuration information and can be used as a 
general database containing any type of information the user desires to store. 
15 The database may be accessed by an administrator desiring to configure a 
computer. When configuring a computer for network accessibility, the 
database may be modified directly using the Network Setup Control Panel. 
One embodiment of the invention provides for modification of the database 
and computer configuration through scripting. 

20 

To modify a configuration by scripting, the invention provides for a 
Scripting Interface consisting of a Scripting Server and Scripting Plug-In. The 
Scripting Server is programmed with the general knowledge of the structure 
and type of objects representing configurations stored in the database. The 
25 Scripting Server receives the script forwarded from a user or network 

administrator, parses the script and determines the appropriate Scripting 
Plug-In to forward the desired action to (by accessing the general knowledge 
the Scripting Server maintains). The Scripting Plug-In is programmed to 



wo 99/57957 



8 



PCTAJS99/09797 



maintain knowledge of the specific fields and methods of the objects stored in 
the database. Thus, the Scripting Plug-In receives the commands and 
executes the appropriate actions to modify the configuration as directed. 

5 To create a script, one embodiment of the invention provides for the 

use of a dictionary containing available commands and objects that may be 
modified. After creating a script, the administrator merely executes the script 
on a copy of the Scripting Server that is run either remotely or locally. In this 
manner, a computer may be configured using scripting. 

10 

In addition, one embodiment of the invention provides for backwards 
compatibility with prior art configuration settings (using the file formats that 
existed in the prior art). The backwards compatibility method includes 
exporting and importing various configuration settings into the consolidated 
15 database. 
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BRIEF DESCRIPTION OF THE DRAWINGS 

Figure 1 is a block diagram of one embodiment of a computer system 
capable of providing a suitable execution environment for an embodiment of 
5 the invention. 

Figure 2 illustrates the multiple reader protection provided by one 
embodiment of the invention. 

10 Figure 3 illustrates the method of processing scripts provided by one 

embodiment of the invention. 

Figure 4a demonstrates the architectural design of one embodiment of 
the invention. 

15 

Figure 4b demonstrates the architectural design of figure 4a customized 
for network configuration of one embodiment of the invention 

Figure 5 illustrates the file mapping used to combine incompatible file 
20 formats of one embodiment of the invention. 

Figure 6 demonstrates the architectural design of figure 4b customized 
with an additional library to enable additional features of one embodiment of 
the invention. 

25 

Figures 7 and 8 illustrate a method for enabling backwards 
compatibility with prior art file formats provided by one embodiment of the 
invention. 
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Figure 9 illustrates a method for performing a computer configuration 
of one embodiment of the invention. 

Figure 10 demonstrates a database of one embodiment of the 
invention. 

Figure 11 is a screen print-out of a combined Network Setup Control 
Panel of one embodiment of the invention. 
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DETAILED DESCRIPTION OF THE INVENTION 

The invention is a method and apparatus for configuring a computer. 
In the following description, numerous specific details are set forth to 
5 provide a more thorough description of embodiments of the invention. It is 
apparent, however, to one skilled in the art, that the invention may be 
practiced without these specific details. In other instances, well known 
features have not been described in detail so as not to obscure the invention. 

10 Embodiment of Computer Execution Environment ('Hardware'^ 

An embodiment of the invention can be implemented as computer 
software in the form of computer readable code executed on a general 
purpose computer such as computer 100 illustrated in Figure 1, or in the form 

15 of bytecode class files rimning on such a computer. A keyboard 110 and 

mouse 111 are coupled to a bi-directional system bus 118. The keyboard and 
mouse are for introducing user input to the computer system and 
communicating that user input to processor 113. Other suitable input devices 
may be used in addition to, or in place of, the mouse 111 and keyboard 110. 

20 I/O (input/output) unit 119 coupled to bi-directional system bus 118 
represents such I/O elements as a printer, A/V (audio/video) I/O, etc. 

Computer 100 includes a video memory 114, main memory 115 and 
mass storage 112, all coupled to bi-directional system bus 118 along with 
25 keyboard 110, mouse 111 and processor 113. The mass storage 112 may 
include both fixed and removable media, such as magnetic, optical or 
magnetic optical storage systems or any other available mass storage 
technology. Bus 118 may contain, for example, thirty-two address lines for 
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addressing video memory 114 or main memory 115. The system bus 118 also 
includes, for example, a 32-bit data bus for transferring data between and 
among the components, such as processor 113, main memory 115, video 
memory 114 and mass storage 112. Alternatively, multiplex data/address 
lines may be used instead of separate data and address lines. 

In one embodiment of the invention, the processor 113 is a 
microprocessor manufactured by Motorola, such as the 680X0 processor or a 
microprocessor manufactured by Intel, such as the 80X86, or Pentium 
processor. However, any other suitable microprocessor or microcomputer 
may be utilized. Main memory 115 is comprised of dynamic random access 
memory (DRAM). Video memory 114 is a dual-ported video random access 
memory. One port of the video memory 114 is coupled to video amplifier 
116. The video amplifier 116 is used to drive the cathode ray tube (CRT) 
raster monitor 117. Video amplifier 116 is well known in the art and may be 
implemented by any suitable apparatus. This circuitry converts pixel data 
stored in video memory 114 to a raster signal suitable for use by monitor 117. 
Monitor 117 is a type of monitor suitable for displaying graphic images. 

Computer 100 may also include a communication interface 120 
coupled to bus 118. Communication interface 120 provides a two-way data 
communication coupling via a network link 121 to a local network 122. For 
example, if communication interface 120 is an integrated services digital 
network (ISDN) card or a modem, communication interface 120 provides a 
data communication connection to the corresponding type of telephone line, 
which comprises part of network link 121. If communication interface 120 is 
a local area network (LAN) card, communication interface 120 provides a data 
communication connection via network link 121 to a compatible LAN. 
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Wireless links are also possible. In any such implementation, 
communication interface 120 sends and receives electrical, electromagnetic or 
optical signals which carry digital data streams representing various types of 
information. 

5 

Network link 121 typically provides data communication through one 
or more networks to other data devices. For example, network link 121 may 
provide a connection through local network 122 to local server computer 123 
or to data equipment operated by an Internet Service Provider (ISP) 124. ISP 

10 124 in turn provides data communication services through the world wide 
packet data communication network now commonly referred to as the 
"Internet" 125. Local network 122 and Internet 125 both use electrical, 
electromagnetic or optical signals which carry digital data streams. The 
signals through the various networks and the signals on network link 121 

15 and through communication interface 120, which carry the digital data to and 
from computer 100, are exemplary forms of carrier waves transporting the 
information. 

Computer 100 can send messages and receive data, including program 
20 code, through the network(s), network link 121, and communication 

interface 120. In the Internet example, remote server computer 126 might 
transmit a requested code for an application program through Internet 125, 
ISP 124, local network 122 and communication interface 120, In accord with 
the invention, one such application is that of remotely configuring a 
25 computer. 

The received code may be executed by processor 113 as it is received, 
and/ or stored in mass storage 112, or other non-volatile storage for later 
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execution. In this manner, computer 100 may obtain application code in the 
form of a carrier wave, 

Application code may be embodied in any form of computer program 
product. A computer program product comprises a medium configured to 
store or transport computer readable code, or in which computer readable 
code may be embedded. Some examples of computer program products are 
CD-ROM disks, ROM cards, floppy disks, magnetic tapes, computer hard 
drives, servers on a network, and carrier waves. 

The computer systems described above are for purposes of example 
only. An embodiment of the invention may be implemented in any type of 
computer system or programming or processing environment. 

Utilization of Computer Software 

As indicated in the background, control panels may contain multiple 
related functions and data structures. To encapsulate these related functions 
and data structures, one embodiment of the invention utilizes a standard 
object oriented programming (OOP) language approach. To provide an 
understanding of encapsulation of related data structures and methods, an 
overview of object-oriented programming is provided below. 

Object-Oriented Programming 

Object-oriented programming is a method of creating computer 
programs by combining certain fundamental building blocks, and creating 
relationships among and between the building blocks. The building blocks in 
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object-oriented programming systems are called "objects." An object is a 
programming unit that groups together a data structure (one or more 
instance variables) and the operations (methods) that can use or affect that 
data. Thus, an object consists of data and one or more operations or 
5 procedures that can be performed on that data. The joining of data and 
operations into a unitary building block is called "encapsulation." 

An object can be instructed to perform one of its methods when it 
receives a "message." A message is a command or instruction sent to the 
10 object to execute a certain method. A message consists of a method selection 
(e.g., method name) and a plurality of arguments. A message tells the 
receiving object what operations to perform. 

One advantage of object-oriented programming is the way in which 
15 methods are invoked. When a message is sent to an object, it is not necessary 
for the message to instruct the object how to perform a certain method. It is 
only necessary to request that the object execute the method. This greatly 
simplifies program development. 

20 Object-oriented programming languages are predominantly based on a 

"class" scheme. The class-based object-oriented programming scheme is 
generally described in Lieberman, "Using Prototypical Objects to Implement 
Shared Behavior in Object-Oriented Systems/' OOPSLA 86 Proceedings, 
September 1986, pp. 214-223. 

25 

A class defines a type of object that typically includes both variables and 
methods for the class. An object class is used to create a particular instance of 
an object. An instance of an object class includes the variables and methods 
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defined for the class. Multiple instances of the same class can be created from 
an object class. Each instance that is created from the object class is said to be 
of the same type or class. 

To illustrate, an employee object class can include "name" and "salary" 
instance variables and a "set_salary" method. Instances of the employee 
object class can be created, or instantiated for each employee in an 
organization. Each object instance is said to be of type "employee." Each 
employee object instance includes "name" and "salary" instance variables 
and the "set_salary" method. The values associated with the "name" and 
"salary" variables in each employee object instance contain the name and 
salary of an employee in the organization. A message can be sent to an 
employee's employee object instance to invoke the "set_salary" method to 
modify the employee's salary (i.e., the value associated with the "salary" 
variable in the employee's employee object). 

A hierarchy of classes can be defined such that an object class definition 
has one or more subclasses. A subclass inherits its parent's (and 
grandparent's etc.) definition. Each subclass in the hierarchy may add to or 
modify the behavior specified by its parent class. Some object-oriented 
programming languages support multiple inheritance where a subclass may 
inherit a class definition from more than one parent class. Other 
programming languages support only single inheritance, where a subclass is 
limited to irJieriting the class definition of only one parent class. 

An object is a generic term that is used in the object-oriented . 
programming environment to refer to a module that contains related code 
and variables. A software application can be written using an object-oriented 
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programming language whereby the program s functionality is implemented 
using objects. The encapsulation provided by objects in an object-oriented 
programming environment may be extended to the notion of control panels 
and representations of the control panel configurations stored in a database. 

5 

Embodiment of Software Apparatus for Configuring a Computer 

One embodiment of the invention provides for the ability to easily and 
10 remotely configure a computer for network accessibility. The multiple 

control panels that are used in the prior art to properly configure a computer 
are consolidated into one Network Control Panel that allows the 
configuration of the various protocols that the computer operating system 
supports. To provide for one Network Control Panel, the present invention 
15 implements several unique features. 

One embodiment of the invention provides for a centralized database 
that remains persistent on the computer that consists of the collected data 
relating to available configuration settings. This database is not limited to 
20 configuration information and can be used as a general database containing 
information the user desires to store. The database may be accessed by an 
administrator desiring to configure any computer. 

The consolidated database provides advantages and features not 
25 available in the prior art. Some of these advantages include: (1) A combined 
uniform database containing a collection of the incompatible file formats for 
the individual configurations; (2) The database may be viewed and read by 
multiple readers and may be modified by one user or writer concurrently (the 
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embodiment provides protection for the readers when the database is 
modified by a writer); (3) The database maintains crash protection; (4) The 
database is capable of receiving remote commands or remote scripting; (5) 
The database maintains backwards compatibility with prior art file formats; 
5 and (6) The database supports a unified mechanism for sorting and sifting 
files by protocol type. 

Centralized Database Features 

10 

Incompatible File Formats 

Existing network configurations are stored in primarily two types of 
incompatible file formats: (1) A format that supports multiple 

15 configurations; and (2) a format that does not support multiple 

configurations. A format that supports multiple configurations allows 
multiple configurations of the same type to be configured and saved at the 
same time (e.g., the user may configure and store several TCP/IP protocols at 
the same time). A format that does not support multiple configurations only 

20 permits one type of each protocol to be active and stored at a time. If the user 
desires to change or modify the active configuration, the user may do so, but 
the prior settings cannot be stored or saved (only the modified version is 
stored and remains active) (e.g., the user may only have one Infrared 
Configuration active or stored on a computer at any one time). To combine 

25 the configurations into a centralized database, these incompatible formats 
have to be reconciled. 
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To create a consolidated database, each file data format of the prior art 
is mapped into a new data format. The new mapped data from each type of 
format may then be stored together in one uniform database. Figure 5 
demonstrates the mapping used to create a consolidated database. Format A 
5 500 supports multiple configurations (but may only allow one configuration 
to be activated at a time). Format B 504 does not support multiple 
configurations at all. Both Format A 500 and Format B 504 are imported or 
mapped into a compatible Format C 502 and 506 respectively. The imported 
configurations 502 and 506 may then be stored in the Database 508. 

10 

One embodiment of the invention provides an additional feature that 
converts formats that do not support multiple configurations into a format 
that supports multiple configurations while maintaining the integrity of the 
file format. This feature is provided by importing the non-multiple 

15 configuration files into the database. The database allows multiple 

configurations to be used and provides for one of the configurations to 
maintain "active" status. When the database is closed, the "active" 
configuration is exported and saved to the non-multiple file format. Thus, 
the database maintains the integrity of the file formats that supports multiple 

20 configurations while simultaneously supporting multiple formats on the 
computer system. 

A more detailed description of the consolidation of the incompatible 
file formats and the non-multiple file format support is explained below. 

25 
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Multiple Concurrent Access Capability 

One embodiment of the invention provides the ability for multiple 
users to access the database concurrently. Figure 2 illustrates a method of one 

5 embodiment that provides for multiple concurrent readers of the database to 
access the most recent and updated version of the database. ^ At step 200, 
multiple users access the database at any one time. At step 202, one of the 
users modifies the database by writing (also referred to as recording or 
"committing") any changes to the database file. During this w^rite transaction, 

10 the database is locked so that no other users may modify the database. At step 
204, a determination is made regarding whether multiple users were 
accessing the database when the database was modified. If multiple users 
were not accessing the database during the modification, the process starts 
over and the user that modified the database (the "writer") is allowed to 

15 continue accessing with other users ("readers"). 

If multiple users were accessing the database when the modification 
was made, the remaining users are notified of the modification at step 206. 
The notification consists of a message being transmitted to the user and if any 

20 operation is attempted on the database by the user, the operation fails. For 
the user to complete any database operation and access the modified version 
of the database, the database file must be closed at step 208. At step 210, the 
database file is reopened in its modified form. In this manner, any program 
that is accessing the database file does not need to be restarted or exited. The 

25 database file being accessed by the program merely needs to be closed and 
reopened. Subsequently, users may access the database as if no change had 
been made at step 200. 
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One embodiment of the invention implements the "write" procedure 
indicated above through various steps. When accessing the database, a 
duplicate copy of the information being viewed (e.g., a configuration set or 
protocol) is copied into a temporary location. Any modifications that are 
5 made prior to being committed are made to the temporary file. Once the 
writer desires to commit any changes, the temporary file is marked as 
"committed" (or alternatively, a duplicate of the temporary file is created and 
labeled as "committed") and the original information is replaced with the 
modified permanent information. Eventually the "committed" file copies 
10 may be deleted. 

Database Crash Protection /Recovery 

15 One embodiment of the invention provides the ability to maintain 

and protect the database if a system failure occurs (i.e., when the computer 
must be restarted or unexpectedly quits the application) while the user is 
attempting to commit modified information to the database. A 
Configuration Library that includes code to maintain and modify the database 

20 may provide this ability. Prior to committing information to the database, a 
flag is set indicating that the information being modified has not yet been 
"committed" to the database. Subsequent to committing the information, the 
flag is set indicating that the "commit" operation has occurred. In the event 
of a system failure, the lock that is placed on the database during a "write" 

25 transaction is released (thus enabling others to access and write to the 
database if needed). 
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The next time a user tries to access the database, it can be determined if 
the modified information was committed by checking the flag. If the flag 
indicates that a "commit" operation has occurred, the user knows that the 
information was recorded and access may continue as normal. If the 
5 committed flag indicates that the "commit" has not yet occurred, the data that 
has not been committed is deleted and the user must restart the modification 
process. In this manner the integrity of the database is maintained even in 
the event of a system failure. 

10 

Remote Commands /Remote Scripting 

One embodiment of the invention provides the ability to perform 
remote scripting. Remote scripting allows an administrator to set up a script 

15 on the administrator's computer to perform a plurality of events sequentially 
on the administrator's computer or on a computer connected to the network. 
In addition, a script can be stored remotely and an administrator or user may 
command the script to run. The ability to run a script to perform a plurality 
of events on the network enables a network administrator to automatically 

20 custom configure each network user's computer from a remote location. 
This capability eliminates the need to physically and manually adjust each 
computer that is connected to the network. If a network contains several 
hundred computers and each has a static IP address that needs to be changed, 
the network administrator saves considerable time by merely creating a script 

25 to adjust the IP address on each user's computer. This also prevents possible 
errors if each computer user were required to manually adjust the computer's 
configuration. 
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The ability to perform remote scripting and the mechanisms that 
provide for scripting are discussed in detail below. 

5 Mechanism for Sorting Database Information 

Traditional databases may be accessible using two components: a key 
and a value. For example, in a database of employees, the key may titled 
NAME, and a Value for any one record in the database may be the name of an 
10 employee such as John Smith. Various other keys may also be utilized such 
as ADDRESS, DEPARTMENT, and SALARY. Database accessibility using key- 
value pairs is more fully described in pending United States Patent 
Application serial no. 08/863,416 entitled "Dynamic Object Communication 
Protocol". 

15 

Referring to Figure 10, one embodiment of the invention provides for 
the database 1006 to be accessible using a three-part key 1000 consisting of 
NAME 1000a, CREATOR 1000b, and TYPE 1000c. Each record 1004 in the 
database has a NAME 1000a associated with it, the name of the CREATOR 

20 1000b of the record, and the TYPE 1000c of record. Further, an arbitrary 

amount of data 1002 may stored in each record. For example, in a database of 
employees, the three-part key for each record consists of the NAME of an 
employee, the name of the CREATOR of that record, and the TYPE of record 
(e.g., an employment record). Using the database in a network configuration 

25 environment, the key would consist of the NAME of the configuration, the 
CREATOR of the configuration, and the TYPE of configuration such, as 
AppleTalk or TCP/IP and each record comprises a configuration. Using the 
three part key, the configurations may be sorted by either the NAME of the 
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configuration, the CREATOR of the configuration or the TYPE of 
configuration. In addition, the user can elect to only view configurations of a 
specific TYPE. 

5 System Confiniration 

To utilize the database to configure a computer system or the network 
configuration on a computer, various utilities or clients are needed. One 
embodiment of the invention provides for a user interface chent and a 
10 scripting interface client. 

User Interface Client 

The User Interface client consolidates all of the existing control panels 
15 into one combined Network Setup control panel as demonstrated by a screen 
print out of the Network Setup Control Panel of one embodiment in Figure 
11. With a consolidated control panel, the user does not need to adjust 
multiple control panels for existing protocols such as the TCP/IP control 
panel and the PPP control panel. The user need only use the one control 
20 panel to adjust all networking capabilities. Further, by consolidating the 

control panels, the configuration or other settings may be checked at the time 
of set-up to ensure that the protocols are compatible (the prior art only detects 
incompatibility at the time of execution or use). 

25 The user interface permits two protocols of the same type to be created 

and active at the same time, referred to as multihoming. Multihoming is 
beneficial when a user has multiple networks connected and being used 
simultaneously. For example, if the user has a network within the user's 
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company (called an intranet) through two different ethernets, multihoming 
allows the user to use two AppleTalk protocols at the same time to permit 
access through both ethernet connections. Through multihoming the 
invention provides for the activation of multiple networks to be active 
5 simultaneously. Another example of multihoming consists of two TCP/IP 
configurations active at the same time which thereby provides the ability to 
have a static IP address and dynamic IP address on the same computer active 
at the same time, 

10 Scripting Interface Client 

The Scripting Interface is a general tool that can be used to access the 
database (remotely or locally) or configure a viser's computer system 
(remotely or locally) (including system settings other than network 
15 configurations). 

The Scripting Interface consists of two components: (1) an Application 
Program or Scripting Server; and (2) Personality Module or Scripting Plug-In. 
By adding various scripting Plug-Ins to the Scripting Server, the Scripting 
20 Interface may be customized for particular purposes. For example, in one 

embodiment of the invention, the Scripting Interface may be customized into 
a Network Scripting Interface. 

Scripting Server 

25 

The Scripting Server component of the Scripting Interface acts as an 
engine. When commands to perform an action are transmitted to the 
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Scripting Interface, the Scripting Server receives the commands. In one 
embodiment, the commands are transmitted in the form of a script. 



In addition to AppleScript, in the Macintosh environment, the 
5 Scripting Server may accept AppleEvents, An AppleEvent provides for 
communication between applications by allowing an application to send a 
command to another application. The Scripting Server component of the 
Scripting Interface may be used to receive either AppleScript or AppleEvents. 
This ability is enabled by utilization of a dictionary (encompassed within a 

10 configuration library that is invoked when the user desires to access the 
database) that describes recognizable script events, and the objects and their 
relationships as they exist in the database. In one embodiment, the dictionary 
consists of the standard dictionary utilized in AppleScript and any extended 
capabilities added by a scripting language programmer. To adequately enable 

15 the Scripting Server, the dictionary must contain a class for each object or 

item that may be configured (e.g., the dictionary must contain a class for each 
protocol such as TCP/IP, AppleTalk, etc.). Further, if a particular 
configuration is expanded and is capable of handling additional features, the 
dictionary and Plug-In must be modified to accommodate the new features. 

20 The following is an example of part of a dictionary: 



25 



30 



begin transaction: Begin a transaction 



begin transaction 

Result: integer - the transaction id number 

end transaction: End a transaction. Any changes will be saved. 



end transaction 



abort transaction: Abort this transaction. Any changes will be 



discarded. 



abort transaction 
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10 



15 



20 



25 



30 



35 



authenticate: Authenticate access to an object 

authenticate reference the object to authenticate 

with password string - the password to authenticate it 



with 



Result: boolean - the result of the authentication 



get protection: Get the protection of a property 

get protection reference the property to examine 

Result: locked/unlocked 
set protection: Set the protection of a property. You must have 



administration access to do this. 

set protection reference - the property to lock or unlock 

to locked/unlocked 
add: Add an object to a configuration set. An object may belong 



to any number of sets. 

add reference - the configuration or transport options to add 

to configuration set - the configuration set to add it to 

remove: Remove an object from a configuration set. This does 
not delete the object. 

remove reference the configuration or transport options to remove 
from configuration set - the configuration set to remove it 

from 

Class configuration: An Open Transport configuration. This is 
an abstract class to make a configuration, make one of the 
sub-classes listed below. 
Plural form: 

configurations 

Properties: 

name string - the name of this configuration 
active boolean -- is this configuration active 
validity boolean [r/o] - validity of this configuration 
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Class configuration set: An Open Transport configuration set 



lural form: 

configuration sets 

Elements: 

configuration by name, by numeric index, satisfying a test, as 
a range of elements 

transport options by name, by numeric index, satisfying a 
test, as a range of elements 
Properties: 

name string - the name of this configuration set 
active boolean is this the active set? 

Class transport options: Options that apply to all 



configurations of the same class. This is an abstract class - to 



make an options object, make one of the subclasses listed 



below. 



Properties: 

name string - the name of this options 
active boolean - are these options active? 

consequence benign/may affect services/must restart 
configuration/must restart protocol/must restart machine 

[r/o] " consequence of changes to this options's settings 

validity boolean [r/o] - validity of this options 

Class AppleTalk configuration: An AppleTalk configuration 



- inherits the properties and 
the addressing scheme of this 



Plural form: 

AppleTalk configurations 

Properties: 

<inheritance> configuration 

elements of an Open Transport configuration 

addressing dynamic/static - 

configuration, - may be locked 

AppleTalk zone string - the zone of this configuration, - may be 
locked 

network ID integer - the network id of this configuration, - may 
be locked 

node ID integer - the node id of this configuration, may be locked 

port modem port/printer port/modem printer 

port/Ethernet/a string - port of this configuration, - may be locked 
protocol AppleTalk [r/o] - protocol of this configuration 

administration password string - password of this 

configuration 

user mode basic/advanced/administration - user mode of 

this configuration 
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Class AppleTalk options: The AppleTalk options 



Plural form: 

AppleTalk transports 

Properties: 

<inheritance> transport options - inherits the properties and 
elements of an Open Transport options 

unload delay intGger unload delay of these options 



10 In this manner, the Scripting Server component is configured to 

maintain knowledge of the general structure and capabilities of the database. 
However, the Scripting Server does not maintain any knowledge about 
particular fields that are in the classes. Based on its knowledge of the 
database, the Scripting Server interprets the commands and determines the 

15 type of object that the desired action is to be performed on. Once determining 
the appropriate object, the Scripting Server forwards the commands to the 
appropriate Scripting Plug-In that has the ability to modify the object. 



Scripting Plug -In 

20 

The Scripting Plug-In receives parsed commands from the Scripting 
Server, Since the Scripting Server is specific to a particular object or type of 
configuration, it maintains knowledge of the individual fields, data 
structures, and methods of each type of configuration, class, or object. 

25 Consequently, when the command is received from the Scripting Server, the 
Scripting Plug-In is able to utilize the necessary method to manipulate the 
field in the database and perform the desired operation or command. Each 
Plug-In maintains the knowledge of the desired classes to manipulate the 
field as necessary. For example, a TCP Plug-In maintains the necessary 

30 knowledge to modify any fields in a TCP configuration. Similarly, an 

AppleTalk Plug-In maintains the necessary information to modify any fields 
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in an AppleTalk Configuration, Further, to ensure that each Plug-In is only 
operating on fields in the appropriate configuration, the sorting and sifting 
capabilities of the database described above are used. 

5 In one embodiment the configuration settings that the Scripting Plug- 

In maintains knowledge about include two parts: (1) Global Settings (referred 
to as Globals); and (2) Configuration Settings. Global settings are those 
settings that are not dependent on the type of configuration and do not 
change from configuration to configuration. In one embodiment, both 

10 Global Settings and Configuration Settings are implemented in an object 

oriented programming language as abstract classes. An abstract class is a class 
that contains functions that are declared but not implemented. In other 
words, an abstract class merely declares its existence and a subclass (a class that 
inherits or descends from the another class) must implement the abstract 

15 methods and protocol specific fields and accessors. For example, in one 
embodiment the abstract methods that must be implemented are: 

(1) ReadSettings: to initialize the object from an entity; 

(2) WriteSettings: to write the object into an entity; and 
20 (3) Clone: to clone the object. 

Further, a "protocol proxy" object that encapsulates all of the protocol 
data and behavior must be implemented. The protocol proxy is responsible 
for: 

25 (1) Reading all of the protocol entities from an area (such as the 

database) and creating corresponding Configuration Settings 
objects; 

(2) Validating the data; 

(3) Interacting with the stack to check the consequences of a new 
30 configuration and reconfigure the stack; and 

(4) Provide the appropriate Control Panel classes to edit the protocol 
Global Settings and other settings. 
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If any change in the system settings are made as a result of the 
operation, the Scripting Plug-In notifies the operating system software so that 
the changes are recognized by the system. 



5 Figure 3 illustrates the interaction between the Scripting Server 

component and Scripting Plug-In component of the Scripting Interface. At 
step 300/ the user or application transmits a command to the Scripting 
Interface. This command may be from a local script on the user's machine, 
from a remote script from a machine somewhere on the network, or from a 

10 remote process running on a machine somewhere on the network. At step 
302, the Scripting Server receives the command. At step 304, the Scripting 
Server interprets the command. The interpretation process consists of the 
Scripting Server parsing the command and determining the type of object 
that the command is to be executed by or on. At step 306, the Scripting Server 

15 forwards the command to the appropriate Scripting Plug-In (which is 

customized for the particular type of object that is to perform the command). 
At step 308, the Scripting Plug-In performs the desired action. At step 310, the 
Scripting Plug-In notifies the operating system software of any system settings 
that have changed. 

20 

Figure 4a illustrates the architectural design of one embodiment of the 
invention. File system 406a contains the general file structure available on 
computer systems and the database of configurations. The Configuration 
Library 404a provides the necessary software, configuration information, 
25 protocol information, and dictionary for use by the scripting interface to 

access and modify the database in the file system 404a. Scripting Server 400a 
receives the commands and determines the appropriate Scripting Plug-In 
402a to forward the command to by examining Configuration Library 404a. 
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Figure 4b illustrates an architectural design of an embodiment for 
network configuration. The Configuration Library 404b contains network 
configuration specific information to enable access to the database. Network 
5 Scripting Server 400b receives the commands, interprets them and forwards 
them to the appropriate Network Scripting Plug-In 402b to modify the desired 
type of protocol (e.g., AppleTalk, TCP/IP, etc.) in the database. 

In addition to utilizing the Scripting Server 400 to access the database, 
10 the database may be accessed and modified directly by any user. However, by 
accessing and modifying the database directly, errors are more likely to occur 
than through utilization of the Scripting Server 400 and Configuration 
Library 404. 

15 In one embodiment of the invention, the creator of a particular Plug-In 

only needs to create a dictionary as described above (and may omit any code 
that provides support for the classes in the dictionary). The dictionary 
specifies that each particular class in the dictionary inherits from a predefined 
class (such as an AppleEventRecord (a Record containing AppleEvents)). In 

20 such an embodiment, the Scripting Server encapsulates the fields that have 
been defined in the dictionary into an AppleEventRecord and writes the 
encapsulated information to the database. The Scripting Server must 
maintain knowledge of how to support the predefined class (e.g., an 
AppleEventRecord). In this manner, the objects and configurations in the 

25 dictionary appear in the database through an interaction with the Scripting 
Server. 
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In addition to the above configurations illustrated in Figure 4, one 
embodiment of the invention continues to provide support for the Location 
Manager such that if the user desires to switch locations, the Location 
Manager may be continue to be used as in the prior art, 

5 

OT Configuration Library 

The database and methods described above provide for data protection, 
crash recovery, sorting and sifting of items by protocol type, and a method for 

10 creating, accessing, and modifying the data. One embodiment of the 

invention provides for an additional Configuration Library that supports a 
broader set of capabilities specific to Network Configuration. Figure 6 
illustrates the architectural design of such an embodiment. Similar to the 
design described in Figure 4b, the underlying File system and database 606, 

15 Network Scripting Server 600, Network Scripting Plug-In 602, and 

Configuration Library 604 remain intact. In addition, an OpenTransport (OT) 
(type of network software product manufactured by Apple Computer, Inc.) or 
Network Configuration Library 608 layer is added to the design. The OT 
Configuration Library 608 provides backwards compatibility such that all 

20 computer systems, old and new have the ability to support multiple 

configurations. This layer of the architectural design may be created and used 
for any type of configuration that requires backwards compatibility. The layer 
need not be specific to network configuration. 

25 The backwards compatibility feature is enabled through an automated 

import-export feature that occurs transparently to the user. Figures 7 and 8 
illustrate this import-export feature. The prior art control panels modify 
their respective files (referred to as legacy files) when a change is made. Each 
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time a change is made to a legacy file, the legacy file is date stamped with the 
date and time the change is made at step 702. The new database containing 
the consolidated information from the prior art control panels is opened or 
accessed by the Scripting Server or Scripting Plug-In at step 704. At step 706, 
5 the date stamp of each legacy file represented in the database is checked. If the 
date stamp matches the date stamp set in the database, execution continues 
normally as indicated in Figure 8 (see below). 

If the date stamp of a legacy file does not match the date stamp expected 
10 in the database, an import operation commences at step 712. A 

determination regarding the type of configuration that is stored in the legacy 
file is made at step 714. If the configuration in the legacy file supports 
multiple configurations, a configuration for each of the multiple 
configurations in the legacy file is made in the new database at step 716. 
15 Additionally, a set of globals are created in the new database at step 718. Thus, 
if there are n configurations in the legacy file, n+2 entries are created in the 
new database (one for each configuration + a set of globals). 

If the legacy file does not support multiple configurations, a 
20 configuration for the legacy file configuration is created in the new database at 
step 720. In, addition, a set of globals are created at step 722. By importing the 
legacy file configuration into the new database, the user is given the 
opportunity to create an additional instance of the current configuration with 
slightly different settings. This opportunity essentially converts the non- 
25 multiple configuration legacy files into a system that supports multiple 
configurations. 



wo 99/57957 



35 



PCT/US99/09797 



Referring to Figure 8, execution of the desired action continues until 
completion (often symbolized by the close of the new database) at step 800. 
When the user ends his/her transaction (by completing the "write" operation 
on the database), an export operation commences at step 802. A 
5 determination is made as to whether the legacy files support multiple 

configurations at step 804. If the legacy files support multiple configurations, 
the configurations in the new database are matched up with the appropriate 
legacy files and the configurations in the database are written to the legacy 
files in the old legacy file format at step 806. At step 808, any new 

10 configurations in the database that do not have corresponding legacy files 

(i.e., newly created configurations) are written to an existing or newly created 
legacy file in the old legacy file format. At step 810, the global settings from 
the new database are written to the legacy files. The date stamp indicating the 
date and time the legacy file was just modified is captured at step 816 and 

15 recorded in the database at step 818. 

If the legacy files do not support multiple configurations (as 
determined at step 804), the currently active configuration is written to the 
legacy file in the old legacy file format at step 812. By only writing the 

20 currently active configuration to the legacy file, the old file format (which 
only supports one configuration at a time) is preserved while at the same 
time the new database continues to provide support for multiple 
configurations. To change the currently active configuration in the legacy 
file, the user simply designates a new active configuration in the database 

25 which starts the import-export procedure (the import-export procedure 
commences because a change in a configuration causes the database to be 
opened, a "write" to the database occurs, or the database is closed). The global 
settings are written to the legacy file at step 814, and the date stamp is captured 
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and written to the new database at steps 816 and 818. Upon completing the 
date stamp capture at step 818, the database is ready to receive a new import 
and the process starts over again at step 704. 

5 Referring to Figure 6, the OT Configuration Library 608 provides 

protection and recovery if the system or database is interrupted or crashes. 
The support consists of the database protection available with the 
Configuration Library 604 with an additional export feature to restore the 
legacy files. When the Configuration Library 604 is executing a recovery from 

10 a system interruption or crash, the OT Configuration Library 608 hooks into 
the recovery process and applies the results to the legacy files using the export 
operation set forth in steps 802-818 of Figure 8. Thus, the export operation 
commences as a result of a database recovery operation instead of the normal 
database close operation. Consequently, the legacy files accurately reflect any 

15 change in the database. 

Execution and Use of Scripting to Configure a Computer 

20 To utilize the database, Configuration Libraries, the Scripting Server, 

and Scripting Plug-Ins, a user or network administrator drafts a script. 
Referring to Figure 9, at step 900 script drafting may be performed by 
displaying the dictionary stored in the Configuration Library associated with a 
particular Plug-In which enables the drafter to select the operations and fields 

25 that need to be performed or configured (the Scripting Server may be used to 
display the available dictionaries to the user)-. At step 902 the script is drafted. 
The script may then be launched with a Scripting Server. To ensure that the 
modifications are correct; the script is run on the network administrator's 



wo 99/57957 PCT/US99/09797 

37 



own computer locally first. Subsequently, the remote computer is configured 
to accept remote scripting at step 904. For example, in the Macintosh 
environment, program sharing is turned on and the network administrator 
creates a user that has program sharing access. At step 906, the local script is 
5 launched on the remote computer's scripting server. The script is launched 
remotely merely by specifying the computer that the script is to be run on (i.e.. 
Bob s Computer). In this manner, although the script is local, it is being 
launched remotely, and the database operations described in the script are 
performed on the remote computer's database. 

10 

Thus, a method and apparatus for configuring a computer is described 
in conjunction with one or more specific embodiments. The invention is 
defined by the claims and their full scope of equivalents. 
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CLAIMS 

1. A method for configuring a computer comprising: 
obtaining a script; 

launching said script on a scripting server; and 
modifying configuration settings according to said script. 

2. The method of claim 1 wherein said obtaining step further 
comprises: 

obtaining a dictionary of scriptable commands; and 

programming a script using scriptable commands from said dictionary. 

3. The method of claim 1 wherein said scripting server is located 
on a remote computer. 

4. The method of claim 1 wherein said modifying step comprises: 
parsing said script; 

forwarding commands contained in said script to a Scripting Plug-In; 

and 

modifying configuration settings using said Scripting Plug-In. 

5. The method of claim 1 wherein said modifying step comprises: 
obtaining a database of configuration settings; and 

modifying said configuration settings in said database; 
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6. The method of claim 5 wherein said obtaining a database of 
configuration settings in said database step comprises: 

retrieving configuration settings from existing files; 
obtaining a database capable of storing configuration information; and 
5 storing said configuration settings from said existing files into said 

database of configuration settings; 

7. The method of claim 6 wherein said modifying said 
configuration settings step further comprises: 

10 determining if said existing files have been altered; 

if said existing files have been altered, performing the following steps: 

determining if said existing files support multiple 
configurations; 

obtaining a configuration in said database for each multiple 
15 configuration if said files support multiple configurations; 

obtaining a configuration in said database for said existing file s 
configuration if said configuration does not support multiple 
configurations; 

modifying said configurations in said database. 

20 

8. The method of claim 7 further comprising: 
determining if said existing files support multiple configurations; 
writing said configurations from said database into said existing files if 

said existing files support multiple configurations; and 
25 writing a currently active configuration from said database to said 

existing file if said existing files do not support multiple configurations. 
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9. The method of claim 8 further comprising: 
capturing a date stamp from said existing file; 
recording said date stamp in said database; 

said determining if said configuration has been altered step comprising 
5 comparing said date stamp in said existing file to said recorded date stamp in 
said database. 



10. The method of claim 5 further comprising: 
determining if other users were accessing said database; and 
10 notifying said other users of said modification. 



11. A method for configuring a computer comprising: 
obtaining a database; 

loading said database with configuration settings; and 
15 modifying said configuration settings in said database. 

12. The method of claim 11 wherein said loading step comprises: 
retrieving configuration settings from existing files; and 

storing said configuration settings from said existing files into said 
20 database of configuration settings; 
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13. The method of claim 12 wherein said modifying step comprises: 
determining if said existing files have been altered; 

if said existing files have been altered, performing the following steps: 

determining if said existing files support multiple 
configurations; 

obtaining a configuration in said database for each multiple 
configuration if said files support multiple configurations; 

obtaining a configuration in said database for said existing file's 
configuration if said configuration does not support multiple 
configurations; and 

modifying said configurations in said database. 

14. The method of claim 13 further comprising: 
determining if said existing files support multiple configurations; 
writing said configurations from said database into said existing files if 

said existing files support multiple configurations; and 

writing a currently active configuration from said database to said 
existing file if said existing files do not support multiple configurations. 



15. The method of claim 14 further comprising: 
capturing a date stamp from said existing file; 
recording said date stamp in said database; 

said determining if said configuration has been altered step comprising 
comparing said date stamp in said existing file to said recorded date stamp in 
said database. 
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16. The method of claim 11 further comprising: 
determining if other users were accessing said database; and 
notifying said other users of said modification. 

5 17. The method of claim 1 wherein said coinfguration settings are 

network configuration settings. 

18. The method of claim 11 wherein said configuration settings are 
network configuration settings. 

10 

19. A system comprising 
a processor; 

a memory coupled to said processor; 

object code executed by said processor for providing at least one 
15 method for configuring a computer; 

said object code comprising: 

a method obtaining a script 

a method launching said script on a scripting server; and 
a method modifying configuration settings according to said 

20 script. 

20. The system of claim 19 wherein said method obtaining a script 
comprises: 

a method obtaining a dictionary of scriptable commands; and 
25 a method programming a script using scriptable commands from said 

dictionary. 
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21. The system of claim 19 wherein said scripting server is located 
on a remote computer. 



22. The system of claim 19 wherein said method modifying 
5 comprises: 

a method parsing said script; 

a method forwarding commands contained in said script to a Scripting 
Plug-In; and 

a method modifying configuration settings using said Scripting Plug- 

10 In. 



23. The system of claim 19 wherein said method modifying 
comprises: 

a method obtaining a database of configuration settings; and 
15 a method modifying said configuration settings in said database; 

24. The system of claim 23 wherein said method obtaining a 
database of configuration settings in said database comprises: 

a method retrieving configuration settings from existing files; 
20 a method obtaining a database capable of storing configuration 

information; and 

a method storing said configuration settings from said existing files 
into said database of configuration settings; 
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25. The system of claim 24 wherein said method modifying said 
configuration settings further comprises; 

a method determining if said existing files have been altered; 
if said existing files have been altered, object code configured to 
5 performing the following: 

a method determining if said existing files support multiple 
configurations; 

a method obtaining a configuration in said database for each 
multiple configuration if said files support multiple configurations; 
10 a method obtaining a configuration in said database for said 

existing file's configuration if said configuration does not support multiple 
configurations; 

a method modifying said configurations in said database. 

15 26. The system of claim 25 further comprising: 

a method determining if said existing files support multiple 
configurations; 

a method writing said configurations from said database into said 
existing files if said existing files support multiple configurations; and 
20 a method writing a currently active configuration from said database to 

said existing file if said existing files do not support multiple configurations. 

27. The system of claim 26 further comprising: 
a method capturing a date stamp from said existing file; 
25 a method recording said date stamp in said database; 

said determining if said configuration has been altered method 

comprising a method comparing said date stamp in said existing file to said 

recorded date stamp in said database. 
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28. The system of claim 23 further comprising: 

a method determining if other users were accessing said database; and 
a method notifying said other users of said modification. 



29. A system comprising 
a processor; 

a memory coupled to said processor; 
10 object code executed by said processor for providing at least one 

method for configuring a computer; 
said object code comprising: 

a method obtaining a database; 

a method loading said database with configuration settings; 

15 and 

a method modifying said configuration settings in said 
database. 



30. The system of claim 29 wherein said method loading said 
20 database comprises: 

a method retrieving configuration settings from existing files; and 
a method storing said configuration settings from said existing files 
into said database of configuration settings; 
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31, The system of claim 30 wherein said method modifying 
comprises: 

a method determining if said existing files have been altered; 
if said existing files have been altered, object code configured to 
5 perform the following: 

a method determining if said existing files support multiple 
configurations; 

a method obtaining a configuration in said database for each 
multiple configuration if said files support multiple configurations; 
10 a method obtaining a configuration in said database for said 

existing file's configuration if said configuration does not support 
multiple configurations; and 

a method modifying said configurations in said database. 

15 32. The system of claim 31 further comprising: 

a method determining if said existing files support multiple 
configurations; 

a method writing said configurations from said database into said 
existing files if said existing files support multiple configurations; and 
20 a method writing a currently active configuration from said database to 

said existing file if said existing files do not support multiple configurations. 

33. The system of claim 32 further comprising: 
a method capturing a date stamp from said existing file; 
25 a method recording said date stamp in said database; 

said method determining if said configuration has been altered 

comprising a method comparing said date stamp in said existing file to said 

recorded date stamp in said database. 
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34. The system of claim 29 further comprising: 

a method determining if other users were accessing said database; and 
a method notifying said other users of said modification. 

5 

35. The system of claim 19 wherein said coinfguration settings are 
network configuration settings. 

36. The system of claim 29 wherein said configuration settings are 
10 network configuration settings. 

37. A computer program product comprising 

a computer usable medium having computer readable program code 
embodied therein for configuring a computer, said computer program 
15 product comprising: 

computer readable code configured to cause a computer to obtain a 

scripts- 
computer readable code configured to cause a computer to launch said 
script on a scripting server; and 
20 computer readable code configured to cause a computer to modify 

configuration settings according to said script. 



wo 99/57957 



48 



PCT/US99/09797 



38. The computer program product of claim 37 wherein said 
computer readable code configured to cause a computer to obtain further 
comprises: 

computer readable code configured to cause a computer to obtain a 
5 dictionary of scriptable commands; and 

computer readable code configured to cause a computer to program a 
script using scriptable commands from said dictionary. 

39. The computer program product of claim 37 wherein said 
10 scripting server is located on a remote computer. 

40. The computer program product of claim 37 wherein said 
computer code configured to cause a computer to modify comprises: 

computer readable code configured to cause a computer to parse said 

15 script; 

computer readable code configured to cause a computer to forward 
commands contained in said script to a Scripting Plug-In; and 

computer readable code configured to cause a computer to modify 
configuration settings using said Scripting Plug-In. 

20 

4L The computer program product of claim 37 wherein said 
computer code configured to cause a computer to modify comprises: 

computer readable code configured to cause a computer to obtain a 
database of configuration settings; and 
25 computer readable code configured to cause a computer to modify said 

configuration settings in said database; 
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42. The computer program product of claim 41 wherein said 
computer code configured to cause a computer to obtain a database of 
configuration settings in said database comprises: 

computer readable code configured to cause a computer to retrieve 
5 configuration settings from existing files; 

computer readable code configured to cause a computer to obtain a 
database capable of storing configuration information; and 

computer readable code configured to cause a computer to store said 
configuration settings from said existing files into said database of 
10 configuration settings; 

43. The computer program product of claim 42 wherein said 
computer code configured to cause a computer to modify said configuration 
settings further comprises: 

15 computer readable code configured to cause a computer to determine if 

said existing files have been altered; 

if said existing files have been altered, computer readable code 
configured to cause a computer to: 

determine if said existing files support multiple 
20 configurations; 

obtain a configuration in said database for each multiple 
configuration if said files support multiple configurations; 

obtain a configuration in said database for said existing file's 
configuration if said configuration does not support multiple 
25 configurations; 

modify said configurations in said database. 



4 



WO 99/57957 PCT/US99/09797 

50 



44. The computer program product of claim 43 further comprising: 
computer readable code configured to cause a computer to determine if 

said existing files support multiple configurations; 

computer readable code configured to cause a computer to write said 
5 configurations from said database into said existing files if said existing files 
support multiple configurations; and 

computer readable code configured to cause a computer to write a 
currently active configuration from said database to said existing file if said 
existing files do not support multiple configurations. 

10 

45. The computer program product of claim 44 further comprising: 
computer readable code configured to cause a computer to capture a 

date stamp from said existing file; 

computer readable code configured to cause a computer to record said 
15 date stamp in said database; 

said computer code configured to cause a computer to determine if said 
configuration has been altered comprising computer readable code configured 
to cause a computer to compare said date stamp in said existing file to said 
recorded date stamp in said database. 

20 

46. The computer program product of claim 41 further comprising: 
computer readable code configured to cause a computer to determine if 

other users were accessing said database; and 

computer readable code configured to cause a computer to notify said 
25 other users of said modification. 
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47. A computer program product comprising: 

a computer usable medium having computer readable program code 
embodied therein for configuring a computer, said comptuer program 
product comprising: 

computer readable code configured to cause a computer to obtain a 
database; 

computer readable code configured to cause a computer to load said 
database with configuration settings; and 

computer readable code configured to cause a computer to modify said 
configuration settings in said database. 

48. The computer program product of claim 47 wherein said 
computer code configured to cause a computer to load comprises: 

computer readable code configured to cause a computer to retrieve 
configuration settings from existing files; and 

computer readable code configured to cause a computer to store said 
configuration settings from said existing files into said database of 
configuration settings; 
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49. The computer program product of claim 48 wherein said 
computer code configured to cause a computer to modify comprises: 

computer readable code configured to cause a computer to determine if 
said existing files have been altered; , 
5 if said existing files have been altered, computer readable code 

configured to cause a computer to: 

determine if said existing files support multiple 
configurations; 

obtain a configuration in said database for each multiple 
10 configurahon if said files support multiple configurations; 

obtain a configuration in said database for said existing file s 
configuration if said configuration does not support multiple 
configurations; and 

modify said configurations in said database. 

15 

50. The computer program product of claim 49 further comprising: 
computer readable code configured to cause a computer to determine if 

said existing files support multiple configurations; 

computer readable code configured to cause a computer to write said 
20 configurations from said database into said existing files if said existing files 
support multiple configurations; and 

computer readable code configured to cause a computer to write a 
currently active configuration from said database to said existing file if said 
existing files do not support multiple configurations. 



25 
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51. The computer program product of claim 50 further comprising: 
computer readable code configured to cause a computer to capture a 

date stamp from said existing file; 

computer readable code configured to cause a computer to record said 
date stamp in said database; 

said computer code configured to cause a computer to determine if said 
configuration has been altered step comprising computer readable code 
configured to cause a computer to compare said date stamp in said existing 
file to said recorded date stamp in said database. 

52. The computer program product of claim 47 further comprising: 
computer readable code configured to cause a computer to determine if 

other users were accessing said database; and 

computer readable code configured to cause a compviter to notify said 
other users of said modification. 

53. The computer program product of claim 37 wherein said 
coinfguration settings are network configuration settings. 

54. The computer program product of claim 47 wherein said 
configuration settings are network configuration settings. 

55. An apparatus for configuring a computer comprising: 
means for obtaining a script; 

means for launching said script on a scripting server; and 

means for modifying configuration settings according to said script. 
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56. The apparatus of claim 55 wherein said means for obtaining 
further comprises: 

means for obtaining a dictionary of scriptable commands; and 
means for programming a script using scriptable commands from said 
5 dictionary. 

57. The apparatus of claim 55 wherein said scripting server is 
located on a remote computer. 

10 58. The apparatus of claim 55 wherein said means for modifying 

comprises: 

means for parsing said script; 

means for forwarding commands contained in said script to a Scripting 
Plug-In; and 

15 means for modifying configuration settings using said Scripting Plug- 

In. 



59. The apparatus of claim 55 wherein said means for modifying 
comprises: 

20 means for obtaining a database of configuration settings; and 

means for modifying said configuration settings in said database; 
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60. The method of claim 59 wherein said means for obtaining a 
database of configuration settings in said database comprises: 

means for retrieving configuration settings from existing files; 
means for obtaining a database capable of storing configuration 
5 information; and 

means for storing said configuration settings from said existing files 
into said database of configuration settings; 

61. The method of claim 60 wherein said means for modifying said 
10 configuration settings further comprises: 

means for determining if said existing files have been altered; 

means for determining if said existing files support multiple 
configurations if said existing files have been altered; 

means for obtaining a configuration in said database for each multiple 
15 configuration if said files support multiple configurations; 

means for obtaining a configuration in said database for said existing 
file's configuration if said configuration does not support multiple 
configurations; 

means for modifying said configurations in said database. 

20 

62. The apparatus of claim 61 further comprising: 
means for determining if said existing files support multiple 

configurations; 

means for writing said configurations from said database into said 
25 existing files if said existing files support multiple configurations; and 

means for writing a currently active configuration from said database 
to said existing file if said existing files do not support multiple 
configurations. 
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63. The apparatus of claim 62 further comprising: 
means for capturing a date stamp from said existing file; 
means for recording said date stamp in said database; 

said means for determining if said configuration has been altered 
comprising means for comparing said date stamp in said existing file to said 
recorded date stamp in said database. 

64. The apparatus of claim 59 further comprising: 

means for determining if other users were accessing said database; and 
means for notifying said other users of said modification. 

65. An apparatus for configuring a computer comprising: 
means for obtaining a database; 

means for loading said database with configuration settings; and 
means for modifying said configuration settings in said database. 

66. The apparatus of claim 65 wherein said means for loading 
comprises: 

means for retrieving configuration settings from existing files; and 
means for storing said configuration settings from said existing files 
into said database of configuration settings; 
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67. The apparatus of claim 66 wherein said means for modifying 
comprises: 

means for determining if said existing files have been altered; 
means for determining if said existing files support multiple 
5 configurations if said existing files have been altered; 

means for obtaining a configuration in said database for each multiple 
configuration if said files support multiple configurations; 

means for obtaining a configuration in said database for said existing 
file's configuration if said configuration does not support multiple 
10 configurations; and 

means for modifying said configurations in said database. 

68. The apparatus of claim 67 further comprising: 
means for determining if said existing files support multiple 

configurations; 

means for writing said configurations from said database into said 
existing files if said existing files support multiple configurations; and 

means for writing a currently active configuration from said database 
to said existing file if said existing files do not support multiple 
configurations. 

69. The apparatus of claim 68 further comprising: 
means for capturing a date stamp from said existing file; 
means for recording said date stamp in said database; 

25 said means for determining if said configuration has been altered 

comprising means for comparing said date stamp in said existing file to said 
recorded date stamp in said database. 



15 
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70. The apparatus of claim 65 further comprising: 

means for determining if other users were accessing said database; and 

means for notifying said other users of said modification. 

5 71. The apparatus of claim 55 wherein said coinfguration settings 

are network configuration settings. 

72. The apparatus of claim 65 wherein said configuration settings 
are network configuration settings. 
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